package appagendaprofesores.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import appagendaprofesores.excepcion.DAOExcepcion;
import appagendaprofesores.modelo.Clase;
import appagendaprofesores.util.ConexionBD;

public class ClaseDAO extends BaseDAO {
	
	public Clase insertar(Clase vo) throws DAOExcepcion {
		String query = "insert into clase (fecha, horaInicio, horaFinal, costo, estado, idEstudiante, idProfesor) values (?,?,?,?,?,?,?)";
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, vo.getFecha());
			stmt.setString(2, vo.getHoraInicio());
			stmt.setString(3, vo.getHoraFinal());
			stmt.setDouble(4, vo.getCosto());
			stmt.setString(5, vo.getEstado());
			stmt.setInt(6, vo.getIdEstudiante());
			stmt.setInt(7, vo.getIdProfesor());
			
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo insertar");
			}

			int id = 0;
			query = "select last_insert_id()";
			stmt = con.prepareStatement(query);
			rs = stmt.executeQuery();
		if (rs.next()) {
			id = rs.getInt(1);
		}

		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
		    this.cerrarStatement(stmt);
		    this.cerrarConexion(con);
		}
		return vo;
	}
	
}
